python - 制作具有动态字段数的 Django 表单类
全部标签 我有一个对象数组:[#,#,...]我想将其转换为以id为键,以对象为值的散列。现在我是这样做的,但我知道有更好的方法:users=User.all.reduce({})do|hash,user|hash[user.id]=userhashend预期输出:{1=>#,2=>#,...} 最佳答案 users_by_id=User.all.map{|user|[user.id,user]}.to_h如果您使用的是Rails,ActiveSupport会提供Enumerable#index_by:users_by_id=User.all
我有一个元素数组。如果我执行arr.max,我将获得最大值。但我想获取数组的索引。如何在Ruby中找到它例如a=[3,6,774,24,56,2,64,56,34]=>[3,6,774,24,56,2,64,56,34]>>a.maxa.max=>774我需要知道774的索引,即2。我如何在Ruby中执行此操作? 最佳答案 a.index(a.max)shouldgiveyouwantyouwant 关于ruby-如何找到具有最大值的数组的索引,我们在StackOverflow上找到一个
当字段不为空时,如何限制Rails验证仅在创建时检查或检查?我正在为我正在使用的应用程序创建一个用户设置页面,问题是,当使用表单提供的参数进行更新时,只有在密码和密码确认都存在时才会保存设置。我希望这些密码字段无论如何都在创建时进行验证,但仅在提供时进行更新。 最佳答案 如果你想允许空值使用:allow_blank与验证。classTopic如果您只想在创建时验证,请使用on与验证。classTopic涵盖您的情况:classTopicvalidates:email,presence:true,if::should_validate
使用ruby和新的Activerecord查找列中具有重复值的记录的最佳方法是什么? 最佳答案 将@TuteC翻译成ActiveRecord:sql='SELECTid,COUNT(id)asquantityFROMtypesGROUPBYnameHAVINGquantity>1'#=>Type.select("id,count(id)asquantity").group(:name).having("quantity>1") 关于ruby-如何使用ActiveRecord查找具有重
验证后,我得到一个错误,我返回到:action=>:new。表单上的某些字段已经填写,所以即使在出现错误消息后我也想保留它们。如何实现? 最佳答案 您的View(new.html.erb)如下所示"create"do|f|%>Controller代码(创建方法)defcreate@user=User.new(params[:user])if@user.saveredirect_to:action=>'index'elserender:action=>'new'#youshouldrendertofillfieldsaftererro
也许有人可以帮助我。从像这样的CSV文件开始:Ticker,"Price","MarketCap"ZUMZ,30.00,933.90XTEX,16.02,811.57AAC,9.83,80.02我设法将它们读入数组:require'csv'tickers=CSV.read("stocks.csv",{:headers=>true,:return_headers=>true,:header_converters=>:symbol,:converters=>:all})为了验证数据,这个有效:putstickers[1][:ticker]ZUMZ但是这不是:putstickers[:tic
我今天从Python的角度学习Ruby。我完全没能解决的一件事是装饰器的等价物。为了精简内容,我尝试复制一个简单的Python装饰器:#!/usr/bin/envpythonimportmathdefdocument(f):defwrap(x):print"Iamgoingtosquare",xf(x)returnwrap@documentdefsquare(x):printmath.pow(x,2)square(5)运行这个给我:Iamgoingtosquare525.0因此,我想创建一个函数square(x),但要对其进行装饰,以便它在执行之前提醒我它要对什么进行平方。让我们去掉糖
我有一个变量var="some_name",我想创建一个新对象并将其分配给some_name。我该怎么做?例如var="some_name"some_name=Struct.new(:name)#Ineedthisa=some_name.new('blah')#sothatIcandothis. 最佳答案 您不能在Ruby1.9+中动态创建局部变量(您可以在Ruby1.8中通过eval):eval'foo="bar"'foo#NameError:undefinedlocalvariableormethod`foo'formain:O
我正在寻找在Rails模型中使用持续时间字段的最佳方法。我希望格式为HH:MM:SS(例如:01:30:23)。使用的数据库是本地的sqlite和生产中的Postgres。我也想使用这个字段,这样我就可以查看该字段中的所有对象,并计算出该模型中所有对象的总时间,最后得到如下内容:30recordstotaling45hours,25minutes,and34seconds.那么什么最适合?迁移的字段类型CRUD表单的表单字段(小时、分钟、秒下拉列表?)生成模型中所有记录的总持续时间的成本最低的方法 最佳答案 在您的数据库中存储为整数
我在erb中有一个编辑表单。在代码中我有一个带有选项的选择::gender)%>但是,选择没有显示正确的选择值。我做错了什么?如果我对其进行硬编码,我可以让它工作,但这当然不是一个可行的选择。 最佳答案 在您的代码中,您的options_for_select()调用将所选值设置为“性别”,并且不会尝试使用表单对象中的值。请参阅options_for_select()的文档用于使用示例。options_for_select(['Mare','Stallion','Gelding'],f.object.gender)options_fo